



# UNITED STATES PATENT AND TRADEMARK OFFICE

UNITED STATES DEPARTMENT OF COMMERCE  
United States Patent and Trademark Office  
Address: COMMISSIONER FOR PATENTS  
P.O. Box 1450  
Alexandria, Virginia 22313-1450  
[www.uspto.gov](http://www.uspto.gov)

| APPLICATION NO.                                                      | FILING DATE | FIRST NAMED INVENTOR | ATTORNEY DOCKET NO.         | CONFIRMATION NO. |
|----------------------------------------------------------------------|-------------|----------------------|-----------------------------|------------------|
| 10/087,880                                                           | 03/04/2002  | Mayan Moudgil        | YOR9-2001-0204US1<br>(8728- | 6258             |
| 22150                                                                | 7590        | 11/02/2005           |                             | EXAMINER         |
| F. CHAU & ASSOCIATES, LLC<br>130 WOODBURY ROAD<br>WOODBURY, NY 11797 |             |                      |                             | TSAI, HENRY      |
|                                                                      |             |                      | ART UNIT                    | PAPER NUMBER     |
|                                                                      |             |                      | 2181                        |                  |

DATE MAILED: 11/02/2005

Please find below and/or attached an Office communication concerning this application or proceeding.

|                              |                        |                     |  |
|------------------------------|------------------------|---------------------|--|
| <b>Office Action Summary</b> | <b>Application No.</b> | <b>Applicant(s)</b> |  |
|                              | 10/087,880             | MOUDGILL, MAYAN     |  |
|                              | <b>Examiner</b>        | <b>Art Unit</b>     |  |
|                              | Henry W.H. Tsai        | 2181                |  |

-- The MAILING DATE of this communication appears on the cover sheet with the correspondence address --

#### Period for Reply

A SHORTENED STATUTORY PERIOD FOR REPLY IS SET TO EXPIRE 3 MONTH(S) FROM THE MAILING DATE OF THIS COMMUNICATION.

- Extensions of time may be available under the provisions of 37 CFR 1.136(a). In no event, however, may a reply be timely filed after SIX (6) MONTHS from the mailing date of this communication.
- If the period for reply specified above is less than thirty (30) days, a reply within the statutory minimum of thirty (30) days will be considered timely.
- If NO period for reply is specified above, the maximum statutory period will apply and will expire SIX (6) MONTHS from the mailing date of this communication.
- Failure to reply within the set or extended period for reply will, by statute, cause the application to become ABANDONED (35 U.S.C. § 133). Any reply received by the Office later than three months after the mailing date of this communication, even if timely filed, may reduce any earned patent term adjustment. See 37 CFR 1.704(b).

#### Status

- 1) Responsive to communication(s) filed on 18 August 2005.
- 2a) This action is FINAL.      2b) This action is non-final.
- 3) Since this application is in condition for allowance except for formal matters, prosecution as to the merits is closed in accordance with the practice under *Ex parte Quayle*, 1935 C.D. 11, 453 O.G. 213.

#### Disposition of Claims

- 4) Claim(s) 1,4-15,18 and 19 is/are pending in the application.
  - 4a) Of the above claim(s) \_\_\_\_ is/are withdrawn from consideration.
- 5) Claim(s) \_\_\_\_ is/are allowed.
- 6) Claim(s) 1,4-15,18 and 19 is/are rejected.
- 7) Claim(s) \_\_\_\_ is/are objected to.
- 8) Claim(s) \_\_\_\_ are subject to restriction and/or election requirement.

#### Application Papers

- 9) The specification is objected to by the Examiner.
- 10) The drawing(s) filed on \_\_\_\_ is/are: a) accepted or b) objected to by the Examiner.
 

Applicant may not request that any objection to the drawing(s) be held in abeyance. See 37 CFR 1.85(a).

Replacement drawing sheet(s) including the correction is required if the drawing(s) is objected to. See 37 CFR 1.121(d).
- 11) The oath or declaration is objected to by the Examiner. Note the attached Office Action or form PTO-152.

#### Priority under 35 U.S.C. § 119

- 12) Acknowledgment is made of a claim for foreign priority under 35 U.S.C. § 119(a)-(d) or (f).
  - a) All    b) Some \* c) None of:
    1. Certified copies of the priority documents have been received.
    2. Certified copies of the priority documents have been received in Application No. \_\_\_\_.
    3. Copies of the certified copies of the priority documents have been received in this National Stage application from the International Bureau (PCT Rule 17.2(a)).

\* See the attached detailed Office action for a list of the certified copies not received.

#### Attachment(s)

|                                                                                                                         |                                                                             |
|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 1) <input checked="" type="checkbox"/> Notice of References Cited (PTO-892)                                             | 4) <input type="checkbox"/> Interview Summary (PTO-413)                     |
| 2) <input type="checkbox"/> Notice of Draftsperson's Patent Drawing Review (PTO-948)                                    | Paper No(s)/Mail Date. ____ .                                               |
| 3) <input type="checkbox"/> Information Disclosure Statement(s) (PTO-1449 or PTO/SB/08)<br>Paper No(s)/Mail Date ____ . | 5) <input type="checkbox"/> Notice of Informal Patent Application (PTO-152) |
|                                                                                                                         | 6) <input type="checkbox"/> Other: ____ .                                   |

Art Unit: 2181

**DETAILED ACTION**

***Claim Objections***

1. Claim 10-14 are objected to because of the following informalities: In claim 10, line 6, "write" should read - written-; and line 10, "the at least one register file" should read -the plurality of register files- . Appropriate correction is required.

***Claim Rejections - 35 USC § 102***

2. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that form the basis for the rejections under this section made in this Office action:

A person shall be entitled to a patent unless -

(e) the invention was described in (1) an application for patent, published under section 122(b), by another filed in the United States before the invention by the applicant for patent or (2) a patent granted on an application for patent by another filed in the United States before the invention by the applicant for patent, except that an international application filed under the treaty defined in section 351(a) shall have the effects for purposes of this subsection of an application filed in the United States only if the international application designated the United States and was published under Article 21(2) of such treaty in the English language.

3. Claim 1 is rejected under 35 U.S.C. 102(e) as being anticipated by Van Gageldonk et al. (U.S. Patent Application

Art Unit: 2181

Publication No. 2002/0042909) (hereafter referred to as Van Gageldonk et al.'909).

Referring to claim 1, Van Gageldonk et al.'909, as claimed, a microprocessor for processing instructions (see Fig. 1), comprising: a plurality of clusters (UC1, UC2, ..., UC4, see Fig. 1) for receiving the instructions, each of the clusters having a plurality of functional units (see Paragraph 0023, line 24-last line, such as function units: ALU1, L/S1, BU1, MUL1 in UC1) for executing the instructions; and a plurality of register sub-files (RF1, and RF2, see Fig. 1) each having a plurality of registers (certainly existing in each Register sub-files RF1, RF2, see Fig. 1) for storing data for executing the instructions, wherein the register sub-files (RF1, and RF2 see Fig. 1) each have a same number of registers (see Fig. 1, RF1 and RF2 have the same number of registers); wherein each of the clusters is associated with corresponding one of the register sub-files (see Fig. 1, such as UC1 associated with RF1, UC2 associated with RF1, UC3 associated with RF2, UC4 associated with RF2) so that an instruction dispatched (by such as instruction queue or instruction issuing unit in the Van Gageldonk et al.'909's system) to a cluster is executed by accessing registers in a register sub-file (RF1, and RF2, see Fig. 1) associated with the cluster to which the instruction is

Art Unit: 2181

dispatched, and wherein each of the register sub-files has one write port (result output port, see Paragraph 0023, lines 1-7, regarding one result output port for each of the cluster UC1 to UC4, see also Fig. 1) to which a corresponding cluster sends data to be written into registers in a register sub-file (RF1, and RF2, see Fig. 1) associated with the corresponding cluster (see Fig. 1, such as UC1 associated with RF1, UC2 associated with RF1, UC3 associated with RF2, UC4 associated with RF2).

2. Claims 10, and 11 are rejected under 35 U.S.C. 102(e) as being anticipated by Tremblay et al. (U.S. Patent Application Publication No. 2001/0042190) (hereafter referred to as Tremblay et al.'190).

Referring to claim 10, Tremblay et al.'190 discloses, as claimed, a system for processing an instruction in a microprocessor, comprising: a plurality of clusters (MFU1 622, MFU2 624, MFU3 626, and GFU 620, see Fig. 6) having at least one functional unit (see Paragraph 0064, lines 4-6) for executing the instruction; and a plurality of register files (610, 61, 614, and 616, see Fig. 6) having a predetermined number of physical registers (96 global registers and 32 local register, see Fig. 6) to and from which data is written and read in accordance with the instruction, wherein each of the register

Art Unit: 2181

files (610, 61, 614, and 616, see Fig. 6) has one write port (the write port for the corresponding 32 local register in each register file, see Fig. 6, and see also paragraph 0064, lines 14-16, regarding that the local registers are read and written only by a functional unit associated with a particular register file segment) to which an output of a corresponding cluster (MFU1 622, MFU2 624, MFU3 626, and GFU 620, see Fig. 6) is connected, and data write operation in accordance with the instruction executed by the at least one functional unit (see Paragraph 0035, lines 9-13) is performed by accessing the physical registers of the plurality of register files, and wherein each of the plurality of register files (610, 61, 614, and 616, see Fig. 6) has at least one read port (the read port for the corresponding 96 global register in each register file, see Fig. 6, and paragraph 0064, lines 13-14, regarding that the global registers are read and written by all functional units) from which any of the plurality of clusters can read data (see paragraph 0064, lines 13-14, regarding that the global registers are read and written by all functional units).

As to claim 11, Tremblay et al.'190 also discloses: the at least one cluster includes multiple functional (MFU1 622, MFU2 624, and MFU3 626, see Fig. 6, see also paragraph 0035, lines 11-17, regarding the MFU (media functional unit) is multiple

Art Unit: 2181

single-instruction-multiple-datapath (MSIMD) media function units) each for executing different instructions.

**Claim Rejections - 35 USC § 103**

4. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all obviousness rejections set forth in this Office action:

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are such that the subject matter as a whole would have been obvious at the time the invention was made to a person having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the manner in which the invention was made.

5. Claims 4-9, 15, 16, 18, and 19 are rejected under 35 U.S.C. 103(a) as being unpatentable over Van Gageldonk et al.'909 in view of Levy et al. (U.S. Patent Application Publication No. 2001/0004755) (hereafter referred to as Levy et al.'755).

Referring to independent claim 15, Van Gageldonk et al.'909, as claimed, a method for processing instructions in a microprocessor, comprising the steps of: providing clusters (UC1, UC2, ..., UC4, see Fig. 1) each having functional units (see Paragraph 0023, line 24-last line, such as function units: ALU1, L/S1, BU1, MUL1 in UC1) for executing the instructions; dividing

Art Unit: 2181

a register file into a plurality of register sub-files (RF1, and RF2 see Fig. 1) each having registers (certainly existing in each sub-files RF1, and RF2, see Fig. 1) to store data for executing the instructions; associating each of the register sub-files (RF1, and RF2 see Fig. 1) with corresponding one of the clusters (UC1, UC2, ..., UC4, see Fig. 1);

Providing one write port (result output port, see Paragraph 0023, lines 1-7, regarding one result output port for each of the cluster UC1 to UC4, see also Fig. 1) for each of the register sub-files so that a cluster associated with a register sub-file sends data to be written to a write port of the register sub-file;

selecting (by Van Gageldonk et al.'909's system based on such as the operations defined by the opcode of the instruction) a cluster to which an instruction is dispatched; and dispatching the instruction (by such as instruction queue or instruction issuing unit in the Van Gageldonk et al.'909's system) to the selected cluster (UC1, UC2, ..., UC4, see Fig. 1) wherein the instruction is executed by functional units (see Paragraph 0023, line 24-last line, such as function units: ALU1, L/S1, BU1, MUL1 in UC1).

Van Gageldonk et al.'909 discloses the claimed invention except for: a register-renaming unit for renaming target

Art Unit: 2181

registers in an instruction with registers in a register sub-file associated with a cluster to which the instruction is dispatched (claim 4); the register-renaming unit identifies a register to be used to store a value named by a target register in the instruction (claims 5 and 18); issue-queue units each of which is associated with a corresponding one of the clusters, an issue-queue unit holding instruction renamed by the register-renaming unit until the renamed instruction is issued to be executed in a cluster associated with the issue-queue unit (claims 6 and 19); each of the issue-queue units holds state identifying which instructions need to be executed (claim 7); renaming target registers in the instruction with registers in a register sub-file associated with the selected cluster (claim 15).

Levy et al.'755 shows, a register-renaming unit (Register Handler 28, see Fig. 9) for renaming target registers in an instruction (see Fig. 9 changing from instructions to instructions) with registers in a register sub-file associated with a cluster to which the instruction is dispatched; the register-renaming unit (Register Handler 28, see Fig. 9) identifies a register to be used to store a value named by a target register in the instruction (see Fig. 9 changing from instructions to instructions); issue-queue units (see FP

Art Unit: 2181

instruction queue 32; and Integer instruction queue 30 in Fig.

1) each of which is associated with a corresponding one of the clusters, an issue-queue unit (see FP instruction queue 32; or Integer instruction queue 30 in Fig. 1) holding instruction renamed by the register-renaming unit (Register Handler 28, see Fig. 9) until the renamed instruction is issued to be executed (see EXEC stage 54 in Fig. 2) in a cluster associated with the issue-queue unit (Register Handler 28, see Fig. 9); each of the issue-queue units (Register Handler 28, see Fig. 9) holds state (certainly existing in order to control the instruction issue) identifying which instructions need to be executed; renaming target registers (by Register Handler 28, see Fig. 9) in the instruction with registers (108 see Fig. 9 and Paragraph [0060] on page 5) in a register sub-file associated with the selected cluster.

Van Gageldonk et al.'909's system does not explicitly show using renaming registers. Register reference delay is a bottleneck in the system using a lot of registers inside the register files. Using the renaming registers for dynamic instruction scheduling and dynamic allocating the registers will significantly improve the Van Gageldonk et al.'909's system performance.

Art Unit: 2181

It would have been obvious to one having ordinary skill in the art at the time the invention was made to modify Van Gageldonk et al.'909's system to comprise a register-renaming unit for renaming target registers in an instruction with registers in a register sub-file associated with a cluster to which the instruction is dispatched; the register-renaming unit identifies a register to be used to store a value named by a target register in the instruction; issue-queue units each of which is associated with a corresponding one of the clusters, an issue-queue unit holding instruction renamed by the register-renaming unit until the renamed instruction is issued to be executed in a cluster associated with the issue-queue unit; each of the issue-queue units holds state identifying which instructions need to be executed; and renaming target registers in the instruction with registers in a register sub-file associated with the selected cluster, as taught by Levy et al.'755, in order to facilitate dynamic instruction scheduling for reorder or parallel operations to increase the processor performance for the Van Gageldonk et al.'909's system (see paragraph 0003, lines 1-3, and lines 8-11).

As to claim 8, Van Gageldonk et al.'909 also discloses: an instruction dispatch mechanism (comprising such as instruction queue or instruction issuing unit in the Van Gageldonk et

Art Unit: 2181

al.'909's system) for determining which of the clusters each instruction is dispatched to.

As to claim 9, Van Gageldonk et al.'909 also discloses: the instruction dispatch mechanism (comprising such as instruction queue or instruction issuing unit in the Van Gageldonk et al.'909's system) controls the issue-queue units to determine which of the instructions need to be executed (based on such as the operations defined by the opcode of the instruction).

6. Claims 12-14 are rejected under 35 U.S.C. 103(a) as being unpatentable over Tremblay et al.'190 in view of Levy et al. (U.S. Patent Application Publication No. 2001/0004755) (hereafter referred to as Levy et al.'755).

Tremblay et al.'190 discloses the claimed invention except for: means for renaming architectured registers of the instruction with the physical registers of each of the plurality of register files (claim 12);

the architectured registers are target registers in which a result of the instruction is stored (claim 13); and at least one issue-queue units associated with the plurality of the clusters, an issue-queue unit for holding

Art Unit: 2181

instruction renamed by the means for renaming until the instruction is issued to be executed (claim 14).

Levy et al.'755 shows: means for renaming architectured registers (Register Handler 28, see Fig. 9) of the instruction with the physical registers of each of the plurality of register files;

the architected registers (such as Ar1 and AR2 in Fig. 9) are target registers in which a result of the instruction is stored; and

at least one issue-queue units (see FP instruction queue 32; and Integer instruction queue 30 in Fig. 1) associated with the plurality of the clusters, an issue-queue unit (see FP instruction queue 32; or Integer instruction queue 30 in Fig. 1) for holding instruction renamed by the means for renaming (Register Handler 28, see Fig. 9) until the instruction is issued to be executed (see EXEC stage 54 in Fig. 2) in one of the plurality of clusters.

Tremblay et al.'190's system does not explicitly show using renaming registers. Register reference delay is a bottleneck in the system using a lot of registers inside the register files. Using the renaming registers for dynamic instruction scheduling and dynamic allocating the registers will significantly improve the Tremblay et al.'190's system performance.

It would have been obvious to one having ordinary skill in the art at the time the invention was made to modify Tremblay et al.'190's system to comprise: means for renaming architectured registers of the instruction with the physical registers of each of the plurality of register files (claim 12); the architected registers are target registers in which a result of the instruction is stored (claim 13); and at least one issue-queue units associated with the plurality of the clusters, an issue-queue unit for holding instruction renamed by the means for renaming until the instruction is issued to be executed (claim 14), as taught by Levy et al.'755, in order to facilitate dynamic instruction scheduling for reorder or parallel operations to increase the processor performance for the Van Gageldonk et al.'909's system (see paragraph 0003, lines 1-3, and lines 8-11).

#### **Response to Arguments**

7. Applicant's arguments mailed 8/18/05 have been considered but are moot in view of the new ground(s) of rejection.

**Applicant argues that Van Gageldonk et al.'909 does not disclose register sub-files having a same number of registers.**

Art Unit: 2181

Examiner disagrees with Applicants. As set forth in the are rejection above, Van Gageldonk et al.'909 discloses, as claimed: the register sub-files (RF1, and RF2 see Fig. 1) each have a same number of registers (see Fig. 1, RF1 and RF2 have the same number of registers).

As to claim 10, as set forth in the are rejection above, Tremblay et al.'190 discloses: each of the plurality of register files (610, 61, 614, and 616, see Fig. 6) has at least one read port (the read port for the corresponding 96 global register in each register file, see Fig. 6, and paragraph 0064, lines 13-14, regarding that the global registers are read and written by all functional units) from which any of the plurality of clusters can read data (see paragraph 0064, lines 13-14, regarding that the global registers are read and written by all functional units).

In summary, Van Gageldonk et al.'909; Tremblay et al.'190; and Levy et al.'755 teach the claimed invention.

Art Unit: 2181

**Conclusion**

8. Applicant's amendment necessitated the new ground(s) of rejection presented in this Office action. Accordingly, **THIS ACTION IS MADE FINAL**. See MPEP § 706.07(a). Applicant is reminded of the extension of time policy as set forth in 37 CFR 1.136(a).

A shortened statutory period for reply to this final action is set to expire THREE MONTHS from the mailing date of this action. In the event a first reply is filed within TWO MONTHS of the mailing date of this final action and the advisory action is not mailed until after the end of the THREE-MONTH shortened statutory period, then the shortened statutory period will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 CFR 1.136(a) will be calculated from the mailing date of the advisory action. In no event, however, will the statutory period for reply expire later than SIX MONTHS from the date of this final action.

**Contact Information**

9. Any inquiry concerning this communication or earlier communications from the examiner should be directed to Dr. Henry Tsai whose telephone number is (571) 272-4176. The examiner can normally be reached on Monday-Thursday from 8:00 AM to 5:00 PM.

Art Unit: 2181

If attempts to reach the examiner by telephone are unsuccessful, the examiner supervisor, Dov Popovici, can be reached on (571) 272-4083. Any inquiry of a general nature or relating to the status of this application or proceeding should be directed to **the TC central telephone number, 571-272-2100.**

10. In order to reduce pendency and avoid potential delays, Group 2100 is encouraging FAXing of responses to Office actions directly into **the Group at fax number: 571-273-8300.** This practice may be used for filing papers not requiring a fee. It may also be used for filing papers which require a fee by applicants who authorize charges to a PTO deposit account. Please identify the examiner and art unit at the top of your cover sheet. Papers submitted via FAX into Group 2100 will be promptly forward to the examiner.



HENRY W. H. TSAI  
PRIMARY EXAMINER

October 29, 2005